草庐IT

java - 在java中将UTF-16 unicode字符转换为UTF-8

全部标签

ruby - 将字符串截断为前 n 个单词

将字符串截断为前n个单词的最佳方法是什么? 最佳答案 n=3str="yourlonglonginputstringorwhatever"str.split[0...n].join('')=>"yourlonglong"str.split[0...n]#notethattherearethreedots,whichexcludesn=>["your","long","long"] 关于ruby-将字符串截断为前n个单词,我们在StackOverflow上找到一个类似的问题:

ruby - 将对象数组转换为以字段为键的哈希

我有一个对象数组:[#,#,...]我想将其转换为以id为键,以对象为值的散列。现在我是这样做的,但我知道有更好的方法:users=User.all.reduce({})do|hash,user|hash[user.id]=userhashend预期输出:{1=>#,2=>#,...} 最佳答案 users_by_id=User.all.map{|user|[user.id,user]}.to_h如果您使用的是Rails,ActiveSupport会提供Enumerable#index_by:users_by_id=User.all

ruby-on-rails - 将 Rails 中的主键更改为字符串

所以我有两个模型,State和Acquisition。状态has_many收购。我觉得51条记录的自动递增整数主键相当愚蠢。所以我将州的模型更改为PK(州是两个字母的缩写;我没有在任何地方存储实际的州名称:classState问题是当我创建采集模型时,它将外键列state_id创建为一个整数。更具体地说,脚本/生成的迁移做了:classCreateAcquisitions我假设t.references数据类型将其设置为int。问题是我的Acquisition类上的创建方法试图将状态缩写放入表acquisitions的state_id字段中(是的,它在数据库上称为state_id,即使它

ruby - ruby 1.9 中有没有办法从字符串中删除无效的字节序列?

假设你有一个像"€foo\xA0"这样的字符串,编码为UTF-8,有没有办法从这个字符串中删除无效的字节序列?(所以你得到"€foo")在ruby​​-1.8中,您可以使用Iconv.iconv('UTF-8//IGNORE','UTF-8',"€foo\xA0")但现在已弃用。"€foo\xA0".encode('UTF-8')不执行任何操作,因为它已经是UTF-8。我试过:"€foo\xA0".force_encoding('BINARY').encode('UTF-8',:undef=>:replace,:replace=>'')产生“foo”但这也丢失了有效的多字节字符€

ruby - 从 Ruby 字符串中删除除字母和数字以外的所有字符

我在表单中有一个字符串输入字段。我在paramshash中得到了那个值。我应该如何从该字符串中删除除字母和数字之外的所有字符。 最佳答案 只是为了提醒人们好的'oltr:asdf.tr('^A-Za-z0-9','')找到字符范围的补码并将字符转换为''。我很好奇使用\W字符类是否比范围和gsub与tr更快:require'benchmark'asdf=[('A'..'z').to_a,('0'..'9').to_a].joinputsasdfputsasdf.tr('^A-Za-z0-9','')putsasdf.gsub(/[\

ruby - Consistent String#hash 仅基于字符串的内容

目标:将服务器处理的每个URL映射到0、1、2或3,尽可能均匀分布。虽然documentation因为ruby​​的String#hash方法说它将“根据字符串的长度和内容返回一个散列”,这显然不是全部。给定字符串的哈希在解释器的调用中不一致:$irbruby-1.9.2-p180:001>"foo".hash=>360517580588231756ruby-1.9.2-p180:002>^D$irbruby-1.9.2-p180:001>"foo".hash=>-2716152678666510148这意味着特定字符串的散列值可能会因服务器而异。Rails在内部使用String#ha

ruby-on-rails - 在 Ruby on Rails 中, '#encoding: utf-8' 和 'config.encoding = "utf-8"' 是否不同?

我可以通过在其顶部添加注释行来指定任何ruby​​文件使用特定编码:#encoding:utf-8但是在Rails的config/application.rb中,我发现了这个:config.encoding="utf-8"它们有什么不同吗?如果我设置了config.encoding="utf-8",我还需要#encoding:utf-8吗? 最佳答案 config/application.rb中的config.encoding="utf-8"部分与Rails应如何解释内容有关。ruby文件中的#encoding:utf-8告诉rub

ruby - 单引号字符串中的反斜杠与双引号字符串

如果我在双引号和单引号字符串的开头添加反斜杠+空格,我会得到不同的结果:"\text"'\text'在双引号字符串的输出中我只看到一个空格。在单引号字符串的输出中,我看到反斜杠+空格。那里发生了什么?这是因为'\'在双引号字符串中被解释为特殊字符,但在单引号字符串中字符原样保留?如果我将字符串更改为此,我会看到相同的输出,即单斜杠后跟一个空格,然后是文本:"\\text"'\\text'在这两种情况下,反斜杠都被转义了。我很困惑为什么他们在这种情况下以相同的方式工作。是否有一些规则可以帮助解释单引号字符串和双引号字符串在Ruby中如何处理反斜杠之间的根本区别?

ruby - 如何从 Ruby on Rails 中的字符串值创建变量名?

我想在Controller中创建一个实例变量以在View中使用:foo="bar"instance_variable_set("#{foo}","cornholio")在View中,使用@bar以便:@bar=>"cornholio"这会产生一个错误:'bar'isnotallowedasaninstancevariablename在Rails3.1中工作 最佳答案 这个instance_variable_set("#{foo}","cornholio")需要读取instance_variable_set("@#{foo}","co

ruby - 在 Ruby 中将数组的数组组合成所有可能的组合,仅向前

我有一个数组数组,像这样:[['1','2'],['a','b'],['x','y']]我需要将这些数组组合成一个字符串,其中包含所有三个集合的所有可能组合,仅向前。我已经看到很多以任何顺序排列的集合的所有可能组合的示例,这不是我想要的。例如,我不希望第一组中的任何元素出现在第二组之后,或者第三组中的任何元素出现在第一组或第二组之前,依此类推。因此,对于上面的示例,输出将是:['1ax','1ay','1bx','1by','2ax','2ay','2bx','2by']数组的数量和每组的长度是动态的。有人知道如何在Ruby中解决这个问题吗? 最佳答案